package leetcode.leetcode.editor.cn;
//两个整数之间的 汉明距离 指的是这两个数字对应二进制位不同的位置的数目。 
//
// 给你两个整数 x 和 y，计算并返回它们之间的汉明距离。 
//
// 
//
// 示例 1： 
//
// 
//输入：x = 1, y = 4
//输出：2
//解释：
//1   (0 0 0 1)
//4   (0 1 0 0)
//       ↑   ↑
//上面的箭头指出了对应二进制位不同的位置。
// 
//
// 示例 2： 
//
// 
//输入：x = 3, y = 1
//输出：1
// 
//
// 
//
// 提示： 
//
// 
// 0 <= x, y <= 2³¹ - 1 
// 
// Related Topics 位运算 👍 527 👎 0


public class _461_汉明距离 {
    public static void main(String[] args) {
        Solution solution = new _461_汉明距离().new Solution();
    }

    //leetcode submit region begin(Prohibit modification and deletion)
    class Solution {
        public int hammingDistance(int x, int y) {
            int c = 0;
            for (int i = 1; i <= 32; i++) {
                int a = x>>i &1,b=y>>i&1;
                c+=a^b;
            }
            return c;
        }
    }
//leetcode submit region end(Prohibit modification and deletion)

}